<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="UTF-8" />
        <meta http-equiv="X-UA-Compatible" content="IE=edge" />
        <meta name="viewport" content="width=device-width, initial-scale=1.0" />
        <title>Document</title>
    </head>
    <body>
        <script>
            /* 
            思路：买卖股票的题目最重要的是确定状态
            该题可以确定4个状态 
            0：今天持有股票状态，且是当天买入
            1：持股状态，且当天未买入
            2：不持股状态，当天卖出
            3：不持股状态，当天未卖出
            
            因为冷冻期的存在，所以状态0只能从状态3得到
            
            确定dp数组和下标含义：dp[i][j]表示第i天状态为j的最大利润

            推导
            
            */
            var maxProfit = function (prices) {
                let dp = new Array(prices.length).fill().map(() => new Array(4).fill(0))
                dp[0][0] = dp[0][1] = -prices[0]
                dp[0][2] = dp[0][3] = 0
                for (let i = 1; i < prices.length; i++) {
                    dp[i][0] = dp[i - 1][3] - prices[i]
                    dp[i][1] = Math.max(dp[i - 1][1], dp[i - 1][0])
                    dp[i][2] = Math.max(dp[i - 1][0], dp[i - 1][1]) + prices[i]
                    dp[i][3] = Math.max(dp[i - 1][3], dp[i - 1][2])
                }
                return Math.max(dp[length - 1][2], dp[length - 1][3])
            }
            maxProfit([1, 2, 3, 0, 2])
        </script>
    </body>
</html>
